Run download_data.Rmd and percentage_of_regional_richness.Rmd First!

library(randomForest)
library(reshape2)
library(rpart)
library(ggplot2)
library(tidyverse)

library(multcomp)
library(car)
library(VSURF)

library(boot)
city_data
length(city_data$city_gdp_per_population[!is.na(city_data$city_gdp_per_population)])
[1] 30
length(city_data$percentage_urban_area_as_open_public_spaces[!is.na(city_data$percentage_urban_area_as_open_public_spaces)])
[1] 61
length(city_data$happiness_future_life[!is.na(city_data$happiness_future_life)])
[1] 65
length(city_data$mean_population_exposure_to_pm2_5_2019[!is.na(city_data$mean_population_exposure_to_pm2_5_2019)])
[1] 131
fetch_city_data_for <- function(pool_name, include_city_name = F) {
  results_filename <- paste(paste('percentage_of_regional_richness__output_', pool_name, 'city', 'richness', 'intercept', sep = "_"), "csv", sep = ".")
  results <- read_csv(results_filename)
  
  joined <- left_join(city_data, results)
  
  required_columns <- c("population_growth", "rainfall_monthly_min", "rainfall_annual_average", "rainfall_monthly_max", "temperature_annual_average", "temperature_monthly_min", "temperature_monthly_max", "happiness_negative_effect", "happiness_positive_effect", "happiness_future_life", "number_of_biomes", "realm", "biome_name", "region_20km_includes_estuary", "region_50km_includes_estuary", "region_100km_includes_estuary", "city_includes_estuary", "region_20km_average_pop_density", "region_50km_average_pop_density", "region_100km_average_pop_density", "city_max_pop_density", "city_average_pop_density", "mean_population_exposure_to_pm2_5_2019", "region_20km_cultivated", "region_20km_urban", "region_50km_cultivated", "region_50km_urban", "region_100km_cultivated", "region_100km_urban", "region_20km_elevation_delta", "region_20km_mean_elevation", "region_50km_elevation_delta", "region_50km_mean_elevation", "region_100km_elevation_delta", "region_100km_mean_elevation", "city_elevation_delta", "city_mean_elevation", "urban", "shrubs", "permanent_water", "open_forest", "herbaceous_wetland", "herbaceous_vegetation", "cultivated", "closed_forest", "share_of_population_within_400m_of_open_space", "percentage_urban_area_as_streets", "percentage_urban_area_as_open_public_spaces_and_streets", "percentage_urban_area_as_open_public_spaces", "city_gdp_per_population", "city_ndvi", "city_ssm", "city_susm", "region_20km_ndvi", "region_20km_ssm", "region_20km_susm", "region_50km_ndvi", "region_50km_ssm", "region_50km_susm", "region_100km_ndvi", "region_100km_ssm", "region_100km_susm", "city_percentage_protected", "region_20km_percentage_protected", "region_50km_percentage_protected", "region_100km_percentage_protected", "city_centre_latitude")
  
  if (include_city_name) {
    required_columns <- append(c("name"), required_columns)
  }
  
  required_columns <- append(c("response"), required_columns)
  
  joined[,required_columns]
}
Merlin Response
merlin_city_data <- fetch_city_data_for('merlin')

── Column specification ─────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
cols(
  name = col_character(),
  response = col_double()
)

Joining, by = "name"
merlin_city_data
merlin_city_data_fixed <- rfImpute(response ~ ., merlin_city_data)
     |      Out-of-bag   |
Tree |      MSE  %Var(y) |
 300 |    21.24   117.83 |
     |      Out-of-bag   |
Tree |      MSE  %Var(y) |
 300 |    20.97   116.32 |
     |      Out-of-bag   |
Tree |      MSE  %Var(y) |
 300 |    21.38   118.61 |
     |      Out-of-bag   |
Tree |      MSE  %Var(y) |
 300 |    21.84   121.18 |
     |      Out-of-bag   |
Tree |      MSE  %Var(y) |
 300 |    21.22   117.73 |
merlin_city_data_fixed
ggplot(merlin_city_data_fixed, aes(response)) + geom_histogram(binwidth = 2)

names(merlin_city_data_fixed)
 [1] "response"                                                "population_growth"                                      
 [3] "rainfall_monthly_min"                                    "rainfall_annual_average"                                
 [5] "rainfall_monthly_max"                                    "temperature_annual_average"                             
 [7] "temperature_monthly_min"                                 "temperature_monthly_max"                                
 [9] "happiness_negative_effect"                               "happiness_positive_effect"                              
[11] "happiness_future_life"                                   "number_of_biomes"                                       
[13] "realm"                                                   "biome_name"                                             
[15] "region_20km_includes_estuary"                            "region_50km_includes_estuary"                           
[17] "region_100km_includes_estuary"                           "city_includes_estuary"                                  
[19] "region_20km_average_pop_density"                         "region_50km_average_pop_density"                        
[21] "region_100km_average_pop_density"                        "city_max_pop_density"                                   
[23] "city_average_pop_density"                                "mean_population_exposure_to_pm2_5_2019"                 
[25] "region_20km_cultivated"                                  "region_20km_urban"                                      
[27] "region_50km_cultivated"                                  "region_50km_urban"                                      
[29] "region_100km_cultivated"                                 "region_100km_urban"                                     
[31] "region_20km_elevation_delta"                             "region_20km_mean_elevation"                             
[33] "region_50km_elevation_delta"                             "region_50km_mean_elevation"                             
[35] "region_100km_elevation_delta"                            "region_100km_mean_elevation"                            
[37] "city_elevation_delta"                                    "city_mean_elevation"                                    
[39] "urban"                                                   "shrubs"                                                 
[41] "permanent_water"                                         "open_forest"                                            
[43] "herbaceous_wetland"                                      "herbaceous_vegetation"                                  
[45] "cultivated"                                              "closed_forest"                                          
[47] "share_of_population_within_400m_of_open_space"           "percentage_urban_area_as_streets"                       
[49] "percentage_urban_area_as_open_public_spaces_and_streets" "percentage_urban_area_as_open_public_spaces"            
[51] "city_gdp_per_population"                                 "city_ndvi"                                              
[53] "city_ssm"                                                "city_susm"                                              
[55] "region_20km_ndvi"                                        "region_20km_ssm"                                        
[57] "region_20km_susm"                                        "region_50km_ndvi"                                       
[59] "region_50km_ssm"                                         "region_50km_susm"                                       
[61] "region_100km_ndvi"                                       "region_100km_ssm"                                       
[63] "region_100km_susm"                                       "city_percentage_protected"                              
[65] "region_20km_percentage_protected"                        "region_50km_percentage_protected"                       
[67] "region_100km_percentage_protected"                       "city_centre_latitude"                                   
merlin_response <- merlin_city_data_fixed$response
merlin_predictors <- merlin_city_data_fixed[,-1]
merlin_predictors
merlin_interp <- VSURF(x = merlin_predictors, y  = merlin_response)
Thresholding step
Estimated computational time (on one core): 118.3 sec.

  |                                                                                                                                                     
  |                                                                                                                                               |   0%
  |                                                                                                                                                     
  |===                                                                                                                                            |   2%
  |                                                                                                                                                     
  |======                                                                                                                                         |   4%
  |                                                                                                                                                     
  |=========                                                                                                                                      |   6%
  |                                                                                                                                                     
  |===========                                                                                                                                    |   8%
  |                                                                                                                                                     
  |==============                                                                                                                                 |  10%
  |                                                                                                                                                     
  |=================                                                                                                                              |  12%
  |                                                                                                                                                     
  |====================                                                                                                                           |  14%
  |                                                                                                                                                     
  |=======================                                                                                                                        |  16%
  |                                                                                                                                                     
  |==========================                                                                                                                     |  18%
  |                                                                                                                                                     
  |=============================                                                                                                                  |  20%
  |                                                                                                                                                     
  |===============================                                                                                                                |  22%
  |                                                                                                                                                     
  |==================================                                                                                                             |  24%
  |                                                                                                                                                     
  |=====================================                                                                                                          |  26%
  |                                                                                                                                                     
  |========================================                                                                                                       |  28%
  |                                                                                                                                                     
  |===========================================                                                                                                    |  30%
  |                                                                                                                                                     
  |==============================================                                                                                                 |  32%
  |                                                                                                                                                     
  |=================================================                                                                                              |  34%
  |                                                                                                                                                     
  |===================================================                                                                                            |  36%
  |                                                                                                                                                     
  |======================================================                                                                                         |  38%
  |                                                                                                                                                     
  |=========================================================                                                                                      |  40%
  |                                                                                                                                                     
  |============================================================                                                                                   |  42%
  |                                                                                                                                                     
  |===============================================================                                                                                |  44%
  |                                                                                                                                                     
  |==================================================================                                                                             |  46%
  |                                                                                                                                                     
  |=====================================================================                                                                          |  48%
  |                                                                                                                                                     
  |========================================================================                                                                       |  50%
  |                                                                                                                                                     
  |==========================================================================                                                                     |  52%
  |                                                                                                                                                     
  |=============================================================================                                                                  |  54%
  |                                                                                                                                                     
  |================================================================================                                                               |  56%
  |                                                                                                                                                     
  |===================================================================================                                                            |  58%
  |                                                                                                                                                     
  |======================================================================================                                                         |  60%
  |                                                                                                                                                     
  |=========================================================================================                                                      |  62%
  |                                                                                                                                                     
  |============================================================================================                                                   |  64%
  |                                                                                                                                                     
  |==============================================================================================                                                 |  66%
  |                                                                                                                                                     
  |=================================================================================================                                              |  68%
  |                                                                                                                                                     
  |====================================================================================================                                           |  70%
  |                                                                                                                                                     
  |=======================================================================================================                                        |  72%
  |                                                                                                                                                     
  |==========================================================================================================                                     |  74%
  |                                                                                                                                                     
  |=============================================================================================================                                  |  76%
  |                                                                                                                                                     
  |================================================================================================================                               |  78%
  |                                                                                                                                                     
  |==================================================================================================================                             |  80%
  |                                                                                                                                                     
  |=====================================================================================================================                          |  82%
  |                                                                                                                                                     
  |========================================================================================================================                       |  84%
  |                                                                                                                                                     
  |===========================================================================================================================                    |  86%
  |                                                                                                                                                     
  |==============================================================================================================================                 |  88%
  |                                                                                                                                                     
  |=================================================================================================================================              |  90%
  |                                                                                                                                                     
  |====================================================================================================================================           |  92%
  |                                                                                                                                                     
  |======================================================================================================================================         |  94%
  |                                                                                                                                                     
  |=========================================================================================================================================      |  96%
  |                                                                                                                                                     
  |============================================================================================================================================   |  98%
  |                                                                                                                                                     
  |===============================================================================================================================================| 100%
Interpretation step (on 34 variables)
Estimated computational time (on one core): between 42.5 sec. and  234.6 sec.

  |                                                                                                                                                     
  |                                                                                                                                               |   0%
  |                                                                                                                                                     
  |====                                                                                                                                           |   3%
  |                                                                                                                                                     
  |========                                                                                                                                       |   6%
  |                                                                                                                                                     
  |=============                                                                                                                                  |   9%
  |                                                                                                                                                     
  |=================                                                                                                                              |  12%
  |                                                                                                                                                     
  |=====================                                                                                                                          |  15%
  |                                                                                                                                                     
  |=========================                                                                                                                      |  18%
  |                                                                                                                                                     
  |=============================                                                                                                                  |  21%
  |                                                                                                                                                     
  |==================================                                                                                                             |  24%
  |                                                                                                                                                     
  |======================================                                                                                                         |  26%
  |                                                                                                                                                     
  |==========================================                                                                                                     |  29%
  |                                                                                                                                                     
  |==============================================                                                                                                 |  32%
  |                                                                                                                                                     
  |==================================================                                                                                             |  35%
  |                                                                                                                                                     
  |=======================================================                                                                                        |  38%
  |                                                                                                                                                     
  |===========================================================                                                                                    |  41%
  |                                                                                                                                                     
  |===============================================================                                                                                |  44%
  |                                                                                                                                                     
  |===================================================================                                                                            |  47%
  |                                                                                                                                                     
  |========================================================================                                                                       |  50%
  |                                                                                                                                                     
  |============================================================================                                                                   |  53%
  |                                                                                                                                                     
  |================================================================================                                                               |  56%
  |                                                                                                                                                     
  |====================================================================================                                                           |  59%
  |                                                                                                                                                     
  |========================================================================================                                                       |  62%
  |                                                                                                                                                     
  |=============================================================================================                                                  |  65%
  |                                                                                                                                                     
  |=================================================================================================                                              |  68%
  |                                                                                                                                                     
  |=====================================================================================================                                          |  71%
  |                                                                                                                                                     
  |=========================================================================================================                                      |  74%
  |                                                                                                                                                     
  |=============================================================================================================                                  |  76%
  |                                                                                                                                                     
  |==================================================================================================================                             |  79%
  |                                                                                                                                                     
  |======================================================================================================================                         |  82%
  |                                                                                                                                                     
  |==========================================================================================================================                     |  85%
  |                                                                                                                                                     
  |==============================================================================================================================                 |  88%
  |                                                                                                                                                     
  |==================================================================================================================================             |  91%
  |                                                                                                                                                     
  |=======================================================================================================================================        |  94%
  |                                                                                                                                                     
  |===========================================================================================================================================    |  97%
  |                                                                                                                                                     
  |===============================================================================================================================================| 100%
Prediction step (on 4 variables)
Maximum estimated computational time (on one core): 5.3 sec.

  |                                                                                                                                                     
  |                                                                                                                                               |   0%
  |                                                                                                                                                     
  |====================================                                                                                                           |  25%
  |                                                                                                                                                     
  |========================================================================                                                                       |  50%
  |                                                                                                                                                     
  |===========================================================================================================                                    |  75%
  |                                                                                                                                                     
  |===============================================================================================================================================| 100%
names(merlin_predictors[,merlin_interp$varselect.interp])
[1] "region_50km_elevation_delta" "region_50km_ssm"             "biome_name"                  "region_100km_ssm"           
Birdlife Response
birdlife_city_data <- fetch_city_data_for('birdlife')

── Column specification ─────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
cols(
  name = col_character(),
  response = col_double()
)

Joining, by = "name"
birdlife_city_data
ggplot(birdlife_city_data, aes(response)) + geom_histogram(binwidth = 1)

birdlife_city_data_fixed <- rfImpute(response ~ ., birdlife_city_data)
     |      Out-of-bag   |
Tree |      MSE  %Var(y) |
 300 |    5.895    93.31 |
     |      Out-of-bag   |
Tree |      MSE  %Var(y) |
 300 |    5.618    88.93 |
     |      Out-of-bag   |
Tree |      MSE  %Var(y) |
 300 |    5.764    91.24 |
     |      Out-of-bag   |
Tree |      MSE  %Var(y) |
 300 |    5.757    91.14 |
     |      Out-of-bag   |
Tree |      MSE  %Var(y) |
 300 |    5.725    90.63 |
birdlife_city_data_fixed
names(merlin_city_data_fixed)
 [1] "response"                                                "population_growth"                                      
 [3] "rainfall_monthly_min"                                    "rainfall_annual_average"                                
 [5] "rainfall_monthly_max"                                    "temperature_annual_average"                             
 [7] "temperature_monthly_min"                                 "temperature_monthly_max"                                
 [9] "happiness_negative_effect"                               "happiness_positive_effect"                              
[11] "happiness_future_life"                                   "number_of_biomes"                                       
[13] "realm"                                                   "biome_name"                                             
[15] "region_20km_includes_estuary"                            "region_50km_includes_estuary"                           
[17] "region_100km_includes_estuary"                           "city_includes_estuary"                                  
[19] "region_20km_average_pop_density"                         "region_50km_average_pop_density"                        
[21] "region_100km_average_pop_density"                        "city_max_pop_density"                                   
[23] "city_average_pop_density"                                "mean_population_exposure_to_pm2_5_2019"                 
[25] "region_20km_cultivated"                                  "region_20km_urban"                                      
[27] "region_50km_cultivated"                                  "region_50km_urban"                                      
[29] "region_100km_cultivated"                                 "region_100km_urban"                                     
[31] "region_20km_elevation_delta"                             "region_20km_mean_elevation"                             
[33] "region_50km_elevation_delta"                             "region_50km_mean_elevation"                             
[35] "region_100km_elevation_delta"                            "region_100km_mean_elevation"                            
[37] "city_elevation_delta"                                    "city_mean_elevation"                                    
[39] "urban"                                                   "shrubs"                                                 
[41] "permanent_water"                                         "open_forest"                                            
[43] "herbaceous_wetland"                                      "herbaceous_vegetation"                                  
[45] "cultivated"                                              "closed_forest"                                          
[47] "share_of_population_within_400m_of_open_space"           "percentage_urban_area_as_streets"                       
[49] "percentage_urban_area_as_open_public_spaces_and_streets" "percentage_urban_area_as_open_public_spaces"            
[51] "city_gdp_per_population"                                 "city_ndvi"                                              
[53] "city_ssm"                                                "city_susm"                                              
[55] "region_20km_ndvi"                                        "region_20km_ssm"                                        
[57] "region_20km_susm"                                        "region_50km_ndvi"                                       
[59] "region_50km_ssm"                                         "region_50km_susm"                                       
[61] "region_100km_ndvi"                                       "region_100km_ssm"                                       
[63] "region_100km_susm"                                       "city_percentage_protected"                              
[65] "region_20km_percentage_protected"                        "region_50km_percentage_protected"                       
[67] "region_100km_percentage_protected"                       "city_centre_latitude"                                   
birdlife_response <- birdlife_city_data_fixed$response
birdlife_predictors <- birdlife_city_data_fixed[,-1]
birdlife_predictors
birdlife_interp <- VSURF(x = birdlife_predictors, y  = birdlife_response)
Thresholding step
Estimated computational time (on one core): 103.7 sec.

  |                                                                                                                                                     
  |                                                                                                                                               |   0%
  |                                                                                                                                                     
  |===                                                                                                                                            |   2%
  |                                                                                                                                                     
  |======                                                                                                                                         |   4%
  |                                                                                                                                                     
  |=========                                                                                                                                      |   6%
  |                                                                                                                                                     
  |===========                                                                                                                                    |   8%
  |                                                                                                                                                     
  |==============                                                                                                                                 |  10%
  |                                                                                                                                                     
  |=================                                                                                                                              |  12%
  |                                                                                                                                                     
  |====================                                                                                                                           |  14%
  |                                                                                                                                                     
  |=======================                                                                                                                        |  16%
  |                                                                                                                                                     
  |==========================                                                                                                                     |  18%
  |                                                                                                                                                     
  |=============================                                                                                                                  |  20%
  |                                                                                                                                                     
  |===============================                                                                                                                |  22%
  |                                                                                                                                                     
  |==================================                                                                                                             |  24%
  |                                                                                                                                                     
  |=====================================                                                                                                          |  26%
  |                                                                                                                                                     
  |========================================                                                                                                       |  28%
  |                                                                                                                                                     
  |===========================================                                                                                                    |  30%
  |                                                                                                                                                     
  |==============================================                                                                                                 |  32%
  |                                                                                                                                                     
  |=================================================                                                                                              |  34%
  |                                                                                                                                                     
  |===================================================                                                                                            |  36%
  |                                                                                                                                                     
  |======================================================                                                                                         |  38%
  |                                                                                                                                                     
  |=========================================================                                                                                      |  40%
  |                                                                                                                                                     
  |============================================================                                                                                   |  42%
  |                                                                                                                                                     
  |===============================================================                                                                                |  44%
  |                                                                                                                                                     
  |==================================================================                                                                             |  46%
  |                                                                                                                                                     
  |=====================================================================                                                                          |  48%
  |                                                                                                                                                     
  |========================================================================                                                                       |  50%
  |                                                                                                                                                     
  |==========================================================================                                                                     |  52%
  |                                                                                                                                                     
  |=============================================================================                                                                  |  54%
  |                                                                                                                                                     
  |================================================================================                                                               |  56%
  |                                                                                                                                                     
  |===================================================================================                                                            |  58%
  |                                                                                                                                                     
  |======================================================================================                                                         |  60%
  |                                                                                                                                                     
  |=========================================================================================                                                      |  62%
  |                                                                                                                                                     
  |============================================================================================                                                   |  64%
  |                                                                                                                                                     
  |==============================================================================================                                                 |  66%
  |                                                                                                                                                     
  |=================================================================================================                                              |  68%
  |                                                                                                                                                     
  |====================================================================================================                                           |  70%
  |                                                                                                                                                     
  |=======================================================================================================                                        |  72%
  |                                                                                                                                                     
  |==========================================================================================================                                     |  74%
  |                                                                                                                                                     
  |=============================================================================================================                                  |  76%
  |                                                                                                                                                     
  |================================================================================================================                               |  78%
  |                                                                                                                                                     
  |==================================================================================================================                             |  80%
  |                                                                                                                                                     
  |=====================================================================================================================                          |  82%
  |                                                                                                                                                     
  |========================================================================================================================                       |  84%
  |                                                                                                                                                     
  |===========================================================================================================================                    |  86%
  |                                                                                                                                                     
  |==============================================================================================================================                 |  88%
  |                                                                                                                                                     
  |=================================================================================================================================              |  90%
  |                                                                                                                                                     
  |====================================================================================================================================           |  92%
  |                                                                                                                                                     
  |======================================================================================================================================         |  94%
  |                                                                                                                                                     
  |=========================================================================================================================================      |  96%
  |                                                                                                                                                     
  |============================================================================================================================================   |  98%
  |                                                                                                                                                     
  |===============================================================================================================================================| 100%
Interpretation step (on 53 variables)
Estimated computational time (on one core): between 70.2 sec. and  482.3 sec.

  |                                                                                                                                                     
  |                                                                                                                                               |   0%
  |                                                                                                                                                     
  |===                                                                                                                                            |   2%
  |                                                                                                                                                     
  |=====                                                                                                                                          |   4%
  |                                                                                                                                                     
  |========                                                                                                                                       |   6%
  |                                                                                                                                                     
  |===========                                                                                                                                    |   8%
  |                                                                                                                                                     
  |=============                                                                                                                                  |   9%
  |                                                                                                                                                     
  |================                                                                                                                               |  11%
  |                                                                                                                                                     
  |===================                                                                                                                            |  13%
  |                                                                                                                                                     
  |======================                                                                                                                         |  15%
  |                                                                                                                                                     
  |========================                                                                                                                       |  17%
  |                                                                                                                                                     
  |===========================                                                                                                                    |  19%
  |                                                                                                                                                     
  |==============================                                                                                                                 |  21%
  |                                                                                                                                                     
  |================================                                                                                                               |  23%
  |                                                                                                                                                     
  |===================================                                                                                                            |  25%
  |                                                                                                                                                     
  |======================================                                                                                                         |  26%
  |                                                                                                                                                     
  |========================================                                                                                                       |  28%
  |                                                                                                                                                     
  |===========================================                                                                                                    |  30%
  |                                                                                                                                                     
  |==============================================                                                                                                 |  32%
  |                                                                                                                                                     
  |=================================================                                                                                              |  34%
  |                                                                                                                                                     
  |===================================================                                                                                            |  36%
  |                                                                                                                                                     
  |======================================================                                                                                         |  38%
  |                                                                                                                                                     
  |=========================================================                                                                                      |  40%
  |                                                                                                                                                     
  |===========================================================                                                                                    |  42%
  |                                                                                                                                                     
  |==============================================================                                                                                 |  43%
  |                                                                                                                                                     
  |=================================================================                                                                              |  45%
  |                                                                                                                                                     
  |===================================================================                                                                            |  47%
  |                                                                                                                                                     
  |======================================================================                                                                         |  49%
  |                                                                                                                                                     
  |=========================================================================                                                                      |  51%
  |                                                                                                                                                     
  |============================================================================                                                                   |  53%
  |                                                                                                                                                     
  |==============================================================================                                                                 |  55%
  |                                                                                                                                                     
  |=================================================================================                                                              |  57%
  |                                                                                                                                                     
  |====================================================================================                                                           |  58%
  |                                                                                                                                                     
  |======================================================================================                                                         |  60%
  |                                                                                                                                                     
  |=========================================================================================                                                      |  62%
  |                                                                                                                                                     
  |============================================================================================                                                   |  64%
  |                                                                                                                                                     
  |==============================================================================================                                                 |  66%
  |                                                                                                                                                     
  |=================================================================================================                                              |  68%
  |                                                                                                                                                     
  |====================================================================================================                                           |  70%
  |                                                                                                                                                     
  |=======================================================================================================                                        |  72%
  |                                                                                                                                                     
  |=========================================================================================================                                      |  74%
  |                                                                                                                                                     
  |============================================================================================================                                   |  75%
  |                                                                                                                                                     
  |===============================================================================================================                                |  77%
  |                                                                                                                                                     
  |=================================================================================================================                              |  79%
  |                                                                                                                                                     
  |====================================================================================================================                           |  81%
  |                                                                                                                                                     
  |=======================================================================================================================                        |  83%
  |                                                                                                                                                     
  |=========================================================================================================================                      |  85%
  |                                                                                                                                                     
  |============================================================================================================================                   |  87%
  |                                                                                                                                                     
  |===============================================================================================================================                |  89%
  |                                                                                                                                                     
  |==================================================================================================================================             |  91%
  |                                                                                                                                                     
  |====================================================================================================================================           |  92%
  |                                                                                                                                                     
  |=======================================================================================================================================        |  94%
  |                                                                                                                                                     
  |==========================================================================================================================================     |  96%
  |                                                                                                                                                     
  |============================================================================================================================================   |  98%
  |                                                                                                                                                     
  |===============================================================================================================================================| 100%
Prediction step (on 2 variables)
Maximum estimated computational time (on one core): 2.5 sec.

  |                                                                                                                                                     
  |                                                                                                                                               |   0%
  |                                                                                                                                                     
  |========================================================================                                                                       |  50%
  |                                                                                                                                                     
  |===============================================================================================================================================| 100%
names(birdlife_predictors[,birdlife_interp$varselect.interp])
[1] "population_growth" "region_50km_ssm"  
So….
Merlin: “region_50km_elevation_delta” “biome_name” “region_50km_ssm” “region_100km_ssm” Birdlife: “population_growth” “region_50km_ssm”

Try Modelling

merlin_city_data_named <- fetch_city_data_for('merlin', T)

── Column specification ─────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
cols(
  name = col_character(),
  response = col_double()
)

Joining, by = "name"
birdlife_city_data_named <- fetch_city_data_for('birdlife', T)

── Column specification ─────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
cols(
  name = col_character(),
  response = col_double()
)

Joining, by = "name"
Use cross validation and dropping terms to find best model

full model: response ~ region_100km_ssm + region_50km_ssm + region_50km_elevation_delta + biome_name + population_growth

Merlin data set

merlin_city_data_fixed_no_boreal <- merlin_city_data_fixed[merlin_city_data_fixed$biome_name != 'Boreal Forests/Taiga',]
cv.glm(merlin_city_data_fixed_no_boreal, glm(formula = response ~ region_100km_ssm + region_50km_ssm + region_50km_elevation_delta + biome_name + population_growth, data = merlin_city_data_fixed_no_boreal))$delta[1]
[1] 19.72841

– CVE 19.72841 – Can we drop one?

cv.glm(merlin_city_data_fixed_no_boreal, glm(formula = response ~ region_50km_ssm + region_50km_elevation_delta + biome_name + population_growth, data = merlin_city_data_fixed_no_boreal))$delta[1]
[1] 19.39392
cv.glm(merlin_city_data_fixed_no_boreal, glm(formula = response ~ region_100km_ssm + region_50km_elevation_delta + biome_name + population_growth, data = merlin_city_data_fixed_no_boreal))$delta[1]
[1] 19.3626
cv.glm(merlin_city_data_fixed_no_boreal, glm(formula = response ~ region_100km_ssm + region_50km_ssm + biome_name + population_growth, data = merlin_city_data_fixed_no_boreal))$delta[1]
[1] 19.79173
cv.glm(merlin_city_data_fixed_no_boreal, glm(formula = response ~ region_100km_ssm + region_50km_ssm + region_50km_elevation_delta + population_growth, data = merlin_city_data_fixed_no_boreal))$delta[1]
[1] 18.53183
cv.glm(merlin_city_data_fixed_no_boreal, glm(formula = response ~ region_100km_ssm + region_50km_ssm + region_50km_elevation_delta + biome_name, data = merlin_city_data_fixed_no_boreal))$delta[1]
[1] 19.38052

– drop biome_name to give smaller CVE of 18.53183 – can we drop another?

cv.glm(merlin_city_data_fixed_no_boreal, glm(formula = response ~ region_50km_ssm + region_50km_elevation_delta + population_growth, data = merlin_city_data_fixed_no_boreal))$delta[1]
[1] 18.26184
cv.glm(merlin_city_data_fixed_no_boreal, glm(formula = response ~ region_100km_ssm + region_50km_elevation_delta + population_growth, data = merlin_city_data_fixed_no_boreal))$delta[1]
[1] 18.24017
cv.glm(merlin_city_data_fixed_no_boreal, glm(formula = response ~ region_100km_ssm + region_50km_ssm + population_growth, data = merlin_city_data_fixed_no_boreal))$delta[1]
[1] 18.79038
cv.glm(merlin_city_data_fixed_no_boreal, glm(formula = response ~ region_100km_ssm + region_50km_ssm + region_50km_elevation_delta, data = merlin_city_data_fixed_no_boreal))$delta[1]
[1] 18.20095

– drop population_growth to give CVE of 18.20095 – can we drop another?

cv.glm(merlin_city_data_fixed_no_boreal, glm(formula = response ~ region_50km_ssm + region_50km_elevation_delta, data = merlin_city_data_fixed_no_boreal))$delta[1]
[1] 17.9362
cv.glm(merlin_city_data_fixed_no_boreal, glm(formula = response ~ region_100km_ssm + region_50km_elevation_delta, data = merlin_city_data_fixed_no_boreal))$delta[1]
[1] 17.91216
cv.glm(merlin_city_data_fixed_no_boreal, glm(formula = response ~ region_100km_ssm + region_50km_ssm, data = merlin_city_data_fixed_no_boreal))$delta[1]
[1] 18.48549

– drop region_50km_ssm to give CVE of 17.91216 – can we drop another?

cv.glm(merlin_city_data_fixed_no_boreal, glm(formula = response ~ region_100km_ssm, data = merlin_city_data_fixed_no_boreal))$delta[1]
[1] 18.19515
cv.glm(merlin_city_data_fixed_no_boreal, glm(formula = response ~ region_50km_elevation_delta, data = merlin_city_data_fixed_no_boreal))$delta[1]
[1] 18.04985
– best model with region_100km_ssm + region_50km_elevation_delta (CV error 17.91216)
summary(glm(data = merlin_city_data_fixed, formula = response ~ region_100km_ssm + region_50km_elevation_delta))

Call:
glm(formula = response ~ region_100km_ssm + region_50km_elevation_delta, 
    data = merlin_city_data_fixed)

Deviance Residuals: 
    Min       1Q   Median       3Q      Max  
-7.6599  -2.9987  -0.5524   1.7449  16.9143  

Coefficients:
                              Estimate Std. Error t value Pr(>|t|)  
(Intercept)                  2.6809304  1.1210300   2.391   0.0182 *
region_100km_ssm            -0.1331207  0.0695604  -1.914   0.0578 .
region_50km_elevation_delta -0.0006899  0.0003461  -1.994   0.0482 *
---
Signif. codes:  0 ‘***’ 0.001 ‘**’ 0.01 ‘*’ 0.05 ‘.’ 0.1 ‘ ’ 1

(Dispersion parameter for gaussian family taken to be 17.36262)

    Null deviance: 2469.6  on 136  degrees of freedom
Residual deviance: 2326.6  on 134  degrees of freedom
AIC: 784.8

Number of Fisher Scoring iterations: 2
reg_merlin = glm(data = merlin_city_data_fixed, formula = response ~ region_100km_ssm + region_50km_elevation_delta)
with(summary(reg_merlin), 1 - deviance/null.deviance)
[1] 0.05791102

Birdlife data set

birdlife_city_data_fixed_no_boreal <- birdlife_city_data_fixed[birdlife_city_data_fixed$biome_name != 'Boreal Forests/Taiga',]
cv.glm(birdlife_city_data_fixed_no_boreal, glm(formula = response ~ region_100km_ssm + region_50km_ssm + region_50km_elevation_delta + biome_name + population_growth, data = birdlife_city_data_fixed_no_boreal))$delta[1]
[1] 6.899862

– can we drop a variable?

cv.glm(birdlife_city_data_fixed_no_boreal, glm(formula = response ~ region_50km_ssm + region_50km_elevation_delta + biome_name + population_growth, data = birdlife_city_data_fixed_no_boreal))$delta[1]
[1] 6.768164
cv.glm(birdlife_city_data_fixed_no_boreal, glm(formula = response ~ region_100km_ssm + region_50km_elevation_delta + biome_name + population_growth, data = birdlife_city_data_fixed_no_boreal))$delta[1]
[1] 6.752211
cv.glm(birdlife_city_data_fixed_no_boreal, glm(formula = response ~ region_100km_ssm + region_50km_ssm + biome_name + population_growth, data = birdlife_city_data_fixed_no_boreal))$delta[1]
[1] 6.989636
cv.glm(birdlife_city_data_fixed_no_boreal, glm(formula = response ~ region_100km_ssm + region_50km_ssm + region_50km_elevation_delta + population_growth, data = birdlife_city_data_fixed_no_boreal))$delta[1]
[1] 6.503421
cv.glm(birdlife_city_data_fixed_no_boreal, glm(formula = response ~ region_100km_ssm + region_50km_ssm + region_50km_elevation_delta + biome_name, data = birdlife_city_data_fixed_no_boreal))$delta[1]
[1] 6.780578

– drop biome_name to give CVE of 6.503421 – can we drop another?

cv.glm(birdlife_city_data_fixed_no_boreal, glm(formula = response ~ region_50km_ssm + region_50km_elevation_delta + population_growth, data = birdlife_city_data_fixed_no_boreal))$delta[1]
[1] 6.417311
cv.glm(birdlife_city_data_fixed_no_boreal, glm(formula = response ~ region_100km_ssm + region_50km_elevation_delta + population_growth, data = birdlife_city_data_fixed_no_boreal))$delta[1]
[1] 6.426562
cv.glm(birdlife_city_data_fixed_no_boreal, glm(formula = response ~ region_100km_ssm + region_50km_ssm + population_growth, data = birdlife_city_data_fixed_no_boreal))$delta[1]
[1] 6.430742
cv.glm(birdlife_city_data_fixed_no_boreal, glm(formula = response ~ region_100km_ssm + region_50km_ssm + region_50km_elevation_delta, data = birdlife_city_data_fixed_no_boreal))$delta[1]
[1] 6.439714

– drop region_100km_ssm to give CVE of 6.417311 – can we drop another?

cv.glm(birdlife_city_data_fixed_no_boreal, glm(formula = response ~ region_50km_elevation_delta + population_growth, data = birdlife_city_data_fixed_no_boreal))$delta[1]
[1] 6.535285
cv.glm(birdlife_city_data_fixed_no_boreal, glm(formula = response ~ region_50km_ssm + population_growth, data = birdlife_city_data_fixed_no_boreal))$delta[1]
[1] 6.342025
cv.glm(birdlife_city_data_fixed_no_boreal, glm(formula = response ~ region_50km_ssm + region_50km_elevation_delta, data = birdlife_city_data_fixed_no_boreal))$delta[1]
[1] 6.352664

– drop region_50km_elevation_delta to give CVE of 6.342025 – can we drop another?

cv.glm(birdlife_city_data_fixed_no_boreal, glm(formula = response ~ population_growth, data = birdlife_city_data_fixed_no_boreal))$delta[1]
[1] 6.464699
cv.glm(birdlife_city_data_fixed_no_boreal, glm(formula = response ~ region_50km_ssm, data = birdlife_city_data_fixed_no_boreal))$delta[1]
[1] 6.291299

– drop city_gdp_per_population to give CVE of 6.291299 – is this better than no variable?

cv.glm(birdlife_city_data_fixed_no_boreal, glm(formula = response ~ 1, data = birdlife_city_data_fixed_no_boreal))$delta[1]
[1] 6.395701

– yes, just!

– so best model with birdlife is region_50km_ssm
summary(glm(data = birdlife_city_data_fixed, formula = response ~ region_50km_ssm))

Call:
glm(formula = response ~ region_50km_ssm, data = birdlife_city_data_fixed)

Deviance Residuals: 
    Min       1Q   Median       3Q      Max  
-4.5353  -1.5461  -0.4124   1.3071  10.7572  

Coefficients:
                Estimate Std. Error t value Pr(>|t|)  
(Intercept)      1.26916    0.65041   1.951   0.0531 .
region_50km_ssm -0.08499    0.04115  -2.065   0.0408 *
---
Signif. codes:  0 ‘***’ 0.001 ‘**’ 0.01 ‘*’ 0.05 ‘.’ 0.1 ‘ ’ 1

(Dispersion parameter for gaussian family taken to be 6.214378)

    Null deviance: 865.45  on 136  degrees of freedom
Residual deviance: 838.94  on 135  degrees of freedom
AIC: 643.06

Number of Fisher Scoring iterations: 2
reg_birdlife = glm(data = birdlife_city_data_fixed, formula = response ~ region_50km_ssm)
with(summary(reg_birdlife), 1 - deviance/null.deviance)
[1] 0.03062471
ggplot(birdlife_city_data_named, aes(x = region_50km_ssm, y = response)) + geom_point() + geom_smooth(method = "glm")
`geom_smooth()` using formula 'y ~ x'

Check birdlife model fit
birdlife.fit <- glm(data = birdlife_city_data_fixed, formula = response ~ region_50km_ssm)
summary(birdlife.fit)

Call:
glm(formula = response ~ region_50km_ssm, data = birdlife_city_data_fixed)

Deviance Residuals: 
    Min       1Q   Median       3Q      Max  
-4.5353  -1.5461  -0.4124   1.3071  10.7572  

Coefficients:
                Estimate Std. Error t value Pr(>|t|)  
(Intercept)      1.26916    0.65041   1.951   0.0531 .
region_50km_ssm -0.08499    0.04115  -2.065   0.0408 *
---
Signif. codes:  0 ‘***’ 0.001 ‘**’ 0.01 ‘*’ 0.05 ‘.’ 0.1 ‘ ’ 1

(Dispersion parameter for gaussian family taken to be 6.214378)

    Null deviance: 865.45  on 136  degrees of freedom
Residual deviance: 838.94  on 135  degrees of freedom
AIC: 643.06

Number of Fisher Scoring iterations: 2
with(summary(birdlife.fit), 1 - deviance/null.deviance)
[1] 0.03062471
plot(birdlife.fit)

birdlife_city_data_fixed_no_boreal[c(16, 53, 72), c("region_50km_ssm")]
[1] 18.451180  9.961682 11.644862
city_data[c(16, 53, 72), c("name", "region_50km_ssm")]
dat <- predict(glm(formula = response ~ region_50km_ssm, data = birdlife_city_data_named), se.fit=T)

outside_se <- birdlife_city_data_named[birdlife_city_data_named$response < dat$fit - 15* dat$se.fit | birdlife_city_data_named$response > dat$fit + 15 * dat$se.fit,]

ggplot(birdlife_city_data_named, aes(x = region_50km_ssm, y = response)) + 
  geom_point(size=1) + 
  geom_smooth(method = "glm") +
  geom_text(aes(label = name), data = outside_se, size = 3, position = "dodge", vjust = "inward", hjust = "inward", color = "red", angle=-15) +
  geom_point(data = outside_se, color = "red") +
  theme_bw() +
  ylab("City Random Effect Intercept") + xlab("Regional (50km) SSM") + labs(title = "Birdlife")
`geom_smooth()` using formula 'y ~ x'
Warning: Width not defined. Set with `position_dodge(width = ?)`
ggsave("city_effect_richness__output__birdlife.jpg")
Saving 7.29 x 4.51 in image
`geom_smooth()` using formula 'y ~ x'
Warning: Width not defined. Set with `position_dodge(width = ?)`

How much variation have we explained?

birdlife_city_data_named$residuals <- resid(birdlife.fit)
ggplot(birdlife_city_data_named, aes(y = response, x = residuals)) + 
  geom_point() +
  geom_smooth(method = "lm", se = F) +
  labs(title = "Birdlife", subtitle = paste("Correlation", cor(birdlife_city_data_named$residuals, birdlife_city_data_named$response))) +
  theme_bw()
`geom_smooth()` using formula 'y ~ x'

Check Merlin model fit
merlin.fit <- glm(data = merlin_city_data_named, formula = response ~ region_100km_ssm + region_50km_elevation_delta)
summary(merlin.fit)

Call:
glm(formula = response ~ region_100km_ssm + region_50km_elevation_delta, 
    data = merlin_city_data_named)

Deviance Residuals: 
    Min       1Q   Median       3Q      Max  
-7.6599  -2.9987  -0.5524   1.7449  16.9143  

Coefficients:
                              Estimate Std. Error t value Pr(>|t|)  
(Intercept)                  2.6809304  1.1210300   2.391   0.0182 *
region_100km_ssm            -0.1331207  0.0695604  -1.914   0.0578 .
region_50km_elevation_delta -0.0006899  0.0003461  -1.994   0.0482 *
---
Signif. codes:  0 ‘***’ 0.001 ‘**’ 0.01 ‘*’ 0.05 ‘.’ 0.1 ‘ ’ 1

(Dispersion parameter for gaussian family taken to be 17.36262)

    Null deviance: 2469.6  on 136  degrees of freedom
Residual deviance: 2326.6  on 134  degrees of freedom
AIC: 784.8

Number of Fisher Scoring iterations: 2
with(summary(merlin.fit), 1 - deviance/null.deviance)
[1] 0.05791102
plot(merlin.fit)

merlin_city_data_fixed_no_boreal[c(24, 42, 72), c("region_100km_ssm", "region_50km_elevation_delta")]
city_data[c(24, 42, 72), c("name", "region_100km_ssm", "region_50km_elevation_delta")]
ggplot(merlin_city_data_named, aes(x = region_100km_ssm, y = response)) + 
  geom_point(aes(size = region_50km_elevation_delta)) + 
  geom_smooth(method = "glm") +
  theme_bw() +
  theme(legend.position="bottom") +
  ylab("City Random Effect Intercept") + xlab("Regional (100km) SSM") + labs(title = "eBird") + guides(size=guide_legend(title="Regional (50km) Elevation Delta"))
`geom_smooth()` using formula 'y ~ x'
ggsave("city_effect_richness__output__merlin.jpg")
Saving 7.29 x 4.51 in image
`geom_smooth()` using formula 'y ~ x'

How much variation have we explained?

merlin_city_data_named$residuals <- resid(merlin.fit)
ggplot(merlin_city_data_named, aes(y = response, x = residuals)) + 
  geom_point() +
  geom_smooth(method = "lm", se = F) +
  labs(title = "Merlin", subtitle = paste("Correlation", cor(merlin_city_data_named$residuals, merlin_city_data_named$response))) +
  theme_bw()
`geom_smooth()` using formula 'y ~ x'

Check AIC
AIC(
  glm(data = merlin_city_data_fixed, formula = response ~ region_100km_ssm + region_50km_ssm + region_50km_elevation_delta + biome_name + population_growth),
  glm(data = merlin_city_data_fixed, formula = response ~ region_100km_ssm + region_50km_elevation_delta)
)
AIC(
  glm(data = birdlife_city_data_fixed, formula = response ~ region_100km_ssm + region_50km_ssm + region_50km_elevation_delta + biome_name + population_growth),
  glm(data = birdlife_city_data_fixed, formula = response ~ region_50km_ssm)
)
LDG
birdlife_data_with_lat = fetch_city_data_for('birdlife', include_city_name = T)

── Column specification ─────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
cols(
  name = col_character(),
  response = col_double()
)

Joining, by = "name"
dat2 <- predict(glm(formula = response ~ city_centre_latitude, data = birdlife_data_with_lat), se.fit=T)

outside_se <- birdlife_data_with_lat[birdlife_data_with_lat$response < dat2$fit - 15* dat2$se.fit | birdlife_data_with_lat$response > dat2$fit + 15 * dat2$se.fit,]

ggplot(birdlife_data_with_lat, aes(x = city_centre_latitude, y = response)) + 
  geom_point(size=1) + 
  geom_smooth(method = "glm", formula = y ~ I(x^2)) +
  geom_text(aes(label = name), data = outside_se, size = 3, position = "dodge", vjust = "inward", hjust = "inward", color = "red", angle=-15) +
  geom_point(data = outside_se, color = "red") +
  theme_bw() +
  ylab("City Random Effect Intercept") + xlab("Latitude (of city centre)") + labs(title = "Birdlife")
Warning: Width not defined. Set with `position_dodge(width = ?)`
ggsave('city_effect_richness__output__ldg_birdlife.jpg')
Saving 7.29 x 4.51 in image
Warning: Width not defined. Set with `position_dodge(width = ?)`

merlin_data_with_lat = fetch_city_data_for('merlin', include_city_name = T)

── Column specification ─────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
cols(
  name = col_character(),
  response = col_double()
)

Joining, by = "name"
dat2 <- predict(glm(formula = response ~ city_centre_latitude, data = merlin_data_with_lat), se.fit=T)

outside_se <- merlin_data_with_lat[merlin_data_with_lat$response < dat2$fit - 15* dat2$se.fit | merlin_data_with_lat$response > dat2$fit + 15 * dat2$se.fit,]

ggplot(merlin_data_with_lat, aes(x = city_centre_latitude, y = response)) + 
  geom_point(size=1) + 
  geom_smooth(method = "glm", formula = y ~ I(x^2)) +
  geom_text(aes(label = name), data = outside_se, size = 3, position = "dodge", vjust = "inward", hjust = "inward", color = "red", angle=-15) +
  geom_point(data = outside_se, color = "red") +
  theme_bw() +
  ylab("City Random Effect Intercept") + xlab("Latitude (of city centre)") + labs(title = "eBird")
Warning: Width not defined. Set with `position_dodge(width = ?)`
ggsave('city_effect_richness__output__ldg_merlin.jpg')
Saving 7.29 x 4.51 in image
Warning: Width not defined. Set with `position_dodge(width = ?)`

LS0tCnRpdGxlOiAiUiBOb3RlYm9vayIKb3V0cHV0OiBodG1sX25vdGVib29rCi0tLQpSdW4gYGRvd25sb2FkX2RhdGEuUm1kYCBhbmQgYHBlcmNlbnRhZ2Vfb2ZfcmVnaW9uYWxfcmljaG5lc3MuUm1kYCBGaXJzdCEKCmBgYHtyIHNldHVwfQpsaWJyYXJ5KHJhbmRvbUZvcmVzdCkKbGlicmFyeShyZXNoYXBlMikKbGlicmFyeShycGFydCkKbGlicmFyeShnZ3Bsb3QyKQpsaWJyYXJ5KHRpZHl2ZXJzZSkKCmxpYnJhcnkobXVsdGNvbXApCmxpYnJhcnkoY2FyKQpsaWJyYXJ5KFZTVVJGKQoKbGlicmFyeShib290KQpgYGAKCmBgYHtyfQpjaXR5X2RhdGEKYGBgCgpgYGB7cn0KbGVuZ3RoKGNpdHlfZGF0YSRjaXR5X2dkcF9wZXJfcG9wdWxhdGlvblshaXMubmEoY2l0eV9kYXRhJGNpdHlfZ2RwX3Blcl9wb3B1bGF0aW9uKV0pCmxlbmd0aChjaXR5X2RhdGEkcGVyY2VudGFnZV91cmJhbl9hcmVhX2FzX29wZW5fcHVibGljX3NwYWNlc1shaXMubmEoY2l0eV9kYXRhJHBlcmNlbnRhZ2VfdXJiYW5fYXJlYV9hc19vcGVuX3B1YmxpY19zcGFjZXMpXSkKbGVuZ3RoKGNpdHlfZGF0YSRoYXBwaW5lc3NfZnV0dXJlX2xpZmVbIWlzLm5hKGNpdHlfZGF0YSRoYXBwaW5lc3NfZnV0dXJlX2xpZmUpXSkKbGVuZ3RoKGNpdHlfZGF0YSRtZWFuX3BvcHVsYXRpb25fZXhwb3N1cmVfdG9fcG0yXzVfMjAxOVshaXMubmEoY2l0eV9kYXRhJG1lYW5fcG9wdWxhdGlvbl9leHBvc3VyZV90b19wbTJfNV8yMDE5KV0pCmBgYAoKYGBge3J9CmZldGNoX2NpdHlfZGF0YV9mb3IgPC0gZnVuY3Rpb24ocG9vbF9uYW1lLCBpbmNsdWRlX2NpdHlfbmFtZSA9IEYpIHsKICByZXN1bHRzX2ZpbGVuYW1lIDwtIHBhc3RlKHBhc3RlKCdwZXJjZW50YWdlX29mX3JlZ2lvbmFsX3JpY2huZXNzX19vdXRwdXRfJywgcG9vbF9uYW1lLCAnY2l0eScsICdyaWNobmVzcycsICdpbnRlcmNlcHQnLCBzZXAgPSAiXyIpLCAiY3N2Iiwgc2VwID0gIi4iKQogIHJlc3VsdHMgPC0gcmVhZF9jc3YocmVzdWx0c19maWxlbmFtZSkKICAKICBqb2luZWQgPC0gbGVmdF9qb2luKGNpdHlfZGF0YSwgcmVzdWx0cykKICAKICByZXF1aXJlZF9jb2x1bW5zIDwtIGMoInBvcHVsYXRpb25fZ3Jvd3RoIiwgInJhaW5mYWxsX21vbnRobHlfbWluIiwgInJhaW5mYWxsX2FubnVhbF9hdmVyYWdlIiwgInJhaW5mYWxsX21vbnRobHlfbWF4IiwgInRlbXBlcmF0dXJlX2FubnVhbF9hdmVyYWdlIiwgInRlbXBlcmF0dXJlX21vbnRobHlfbWluIiwgInRlbXBlcmF0dXJlX21vbnRobHlfbWF4IiwgImhhcHBpbmVzc19uZWdhdGl2ZV9lZmZlY3QiLCAiaGFwcGluZXNzX3Bvc2l0aXZlX2VmZmVjdCIsICJoYXBwaW5lc3NfZnV0dXJlX2xpZmUiLCAibnVtYmVyX29mX2Jpb21lcyIsICJyZWFsbSIsICJiaW9tZV9uYW1lIiwgInJlZ2lvbl8yMGttX2luY2x1ZGVzX2VzdHVhcnkiLCAicmVnaW9uXzUwa21faW5jbHVkZXNfZXN0dWFyeSIsICJyZWdpb25fMTAwa21faW5jbHVkZXNfZXN0dWFyeSIsICJjaXR5X2luY2x1ZGVzX2VzdHVhcnkiLCAicmVnaW9uXzIwa21fYXZlcmFnZV9wb3BfZGVuc2l0eSIsICJyZWdpb25fNTBrbV9hdmVyYWdlX3BvcF9kZW5zaXR5IiwgInJlZ2lvbl8xMDBrbV9hdmVyYWdlX3BvcF9kZW5zaXR5IiwgImNpdHlfbWF4X3BvcF9kZW5zaXR5IiwgImNpdHlfYXZlcmFnZV9wb3BfZGVuc2l0eSIsICJtZWFuX3BvcHVsYXRpb25fZXhwb3N1cmVfdG9fcG0yXzVfMjAxOSIsICJyZWdpb25fMjBrbV9jdWx0aXZhdGVkIiwgInJlZ2lvbl8yMGttX3VyYmFuIiwgInJlZ2lvbl81MGttX2N1bHRpdmF0ZWQiLCAicmVnaW9uXzUwa21fdXJiYW4iLCAicmVnaW9uXzEwMGttX2N1bHRpdmF0ZWQiLCAicmVnaW9uXzEwMGttX3VyYmFuIiwgInJlZ2lvbl8yMGttX2VsZXZhdGlvbl9kZWx0YSIsICJyZWdpb25fMjBrbV9tZWFuX2VsZXZhdGlvbiIsICJyZWdpb25fNTBrbV9lbGV2YXRpb25fZGVsdGEiLCAicmVnaW9uXzUwa21fbWVhbl9lbGV2YXRpb24iLCAicmVnaW9uXzEwMGttX2VsZXZhdGlvbl9kZWx0YSIsICJyZWdpb25fMTAwa21fbWVhbl9lbGV2YXRpb24iLCAiY2l0eV9lbGV2YXRpb25fZGVsdGEiLCAiY2l0eV9tZWFuX2VsZXZhdGlvbiIsICJ1cmJhbiIsICJzaHJ1YnMiLCAicGVybWFuZW50X3dhdGVyIiwgIm9wZW5fZm9yZXN0IiwgImhlcmJhY2VvdXNfd2V0bGFuZCIsICJoZXJiYWNlb3VzX3ZlZ2V0YXRpb24iLCAiY3VsdGl2YXRlZCIsICJjbG9zZWRfZm9yZXN0IiwgInNoYXJlX29mX3BvcHVsYXRpb25fd2l0aGluXzQwMG1fb2Zfb3Blbl9zcGFjZSIsICJwZXJjZW50YWdlX3VyYmFuX2FyZWFfYXNfc3RyZWV0cyIsICJwZXJjZW50YWdlX3VyYmFuX2FyZWFfYXNfb3Blbl9wdWJsaWNfc3BhY2VzX2FuZF9zdHJlZXRzIiwgInBlcmNlbnRhZ2VfdXJiYW5fYXJlYV9hc19vcGVuX3B1YmxpY19zcGFjZXMiLCAiY2l0eV9nZHBfcGVyX3BvcHVsYXRpb24iLCAiY2l0eV9uZHZpIiwgImNpdHlfc3NtIiwgImNpdHlfc3VzbSIsICJyZWdpb25fMjBrbV9uZHZpIiwgInJlZ2lvbl8yMGttX3NzbSIsICJyZWdpb25fMjBrbV9zdXNtIiwgInJlZ2lvbl81MGttX25kdmkiLCAicmVnaW9uXzUwa21fc3NtIiwgInJlZ2lvbl81MGttX3N1c20iLCAicmVnaW9uXzEwMGttX25kdmkiLCAicmVnaW9uXzEwMGttX3NzbSIsICJyZWdpb25fMTAwa21fc3VzbSIsICJjaXR5X3BlcmNlbnRhZ2VfcHJvdGVjdGVkIiwgInJlZ2lvbl8yMGttX3BlcmNlbnRhZ2VfcHJvdGVjdGVkIiwgInJlZ2lvbl81MGttX3BlcmNlbnRhZ2VfcHJvdGVjdGVkIiwgInJlZ2lvbl8xMDBrbV9wZXJjZW50YWdlX3Byb3RlY3RlZCIsICJjaXR5X2NlbnRyZV9sYXRpdHVkZSIpCiAgCiAgaWYgKGluY2x1ZGVfY2l0eV9uYW1lKSB7CiAgICByZXF1aXJlZF9jb2x1bW5zIDwtIGFwcGVuZChjKCJuYW1lIiksIHJlcXVpcmVkX2NvbHVtbnMpCiAgfQogIAogIHJlcXVpcmVkX2NvbHVtbnMgPC0gYXBwZW5kKGMoInJlc3BvbnNlIiksIHJlcXVpcmVkX2NvbHVtbnMpCiAgCiAgam9pbmVkWyxyZXF1aXJlZF9jb2x1bW5zXQp9CmBgYAoKCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KTWVybGluIFJlc3BvbnNlCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCmBgYHtyfQptZXJsaW5fY2l0eV9kYXRhIDwtIGZldGNoX2NpdHlfZGF0YV9mb3IoJ21lcmxpbicpCm1lcmxpbl9jaXR5X2RhdGEKYGBgCgpgYGB7cn0KbWVybGluX2NpdHlfZGF0YV9maXhlZCA8LSByZkltcHV0ZShyZXNwb25zZSB+IC4sIG1lcmxpbl9jaXR5X2RhdGEpCm1lcmxpbl9jaXR5X2RhdGFfZml4ZWQKYGBgCgpgYGB7cn0KZ2dwbG90KG1lcmxpbl9jaXR5X2RhdGFfZml4ZWQsIGFlcyhyZXNwb25zZSkpICsgZ2VvbV9oaXN0b2dyYW0oYmlud2lkdGggPSAyKQpgYGAKCmBgYHtyfQpuYW1lcyhtZXJsaW5fY2l0eV9kYXRhX2ZpeGVkKQpgYGAKCmBgYHtyfQptZXJsaW5fcmVzcG9uc2UgPC0gbWVybGluX2NpdHlfZGF0YV9maXhlZCRyZXNwb25zZQptZXJsaW5fcHJlZGljdG9ycyA8LSBtZXJsaW5fY2l0eV9kYXRhX2ZpeGVkWywtMV0KbWVybGluX3ByZWRpY3RvcnMKYGBgCgpgYGB7cn0KbWVybGluX2ludGVycCA8LSBWU1VSRih4ID0gbWVybGluX3ByZWRpY3RvcnMsIHkgID0gbWVybGluX3Jlc3BvbnNlKQpgYGAKCmBgYHtyfQpuYW1lcyhtZXJsaW5fcHJlZGljdG9yc1ssbWVybGluX2ludGVycCR2YXJzZWxlY3QuaW50ZXJwXSkKYGBgCgotLS0tLS0tLS0tLS0tLS0tLS0tLS0tCkJpcmRsaWZlIFJlc3BvbnNlCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KYGBge3J9CmJpcmRsaWZlX2NpdHlfZGF0YSA8LSBmZXRjaF9jaXR5X2RhdGFfZm9yKCdiaXJkbGlmZScpCmJpcmRsaWZlX2NpdHlfZGF0YQpgYGAKCgoKYGBge3J9CmdncGxvdChiaXJkbGlmZV9jaXR5X2RhdGEsIGFlcyhyZXNwb25zZSkpICsgZ2VvbV9oaXN0b2dyYW0oYmlud2lkdGggPSAxKQpgYGAKCmBgYHtyfQpiaXJkbGlmZV9jaXR5X2RhdGFfZml4ZWQgPC0gcmZJbXB1dGUocmVzcG9uc2UgfiAuLCBiaXJkbGlmZV9jaXR5X2RhdGEpCmJpcmRsaWZlX2NpdHlfZGF0YV9maXhlZApgYGAKCmBgYHtyfQpuYW1lcyhtZXJsaW5fY2l0eV9kYXRhX2ZpeGVkKQpgYGAKCmBgYHtyfQpiaXJkbGlmZV9yZXNwb25zZSA8LSBiaXJkbGlmZV9jaXR5X2RhdGFfZml4ZWQkcmVzcG9uc2UKYmlyZGxpZmVfcHJlZGljdG9ycyA8LSBiaXJkbGlmZV9jaXR5X2RhdGFfZml4ZWRbLC0xXQpiaXJkbGlmZV9wcmVkaWN0b3JzCmBgYAoKCmBgYHtyfQpiaXJkbGlmZV9pbnRlcnAgPC0gVlNVUkYoeCA9IGJpcmRsaWZlX3ByZWRpY3RvcnMsIHkgID0gYmlyZGxpZmVfcmVzcG9uc2UpCmBgYAoKYGBge3J9Cm5hbWVzKGJpcmRsaWZlX3ByZWRpY3RvcnNbLGJpcmRsaWZlX2ludGVycCR2YXJzZWxlY3QuaW50ZXJwXSkKYGBgCgoKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tClNvLi4uLgotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KTWVybGluOiAicmVnaW9uXzUwa21fZWxldmF0aW9uX2RlbHRhIiAiYmlvbWVfbmFtZSIgInJlZ2lvbl81MGttX3NzbSIgInJlZ2lvbl8xMDBrbV9zc20iCkJpcmRsaWZlOiAicG9wdWxhdGlvbl9ncm93dGgiICJyZWdpb25fNTBrbV9zc20iICAKCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tClRyeSBNb2RlbGxpbmcKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCgpgYGB7cn0KbWVybGluX2NpdHlfZGF0YV9uYW1lZCA8LSBmZXRjaF9jaXR5X2RhdGFfZm9yKCdtZXJsaW4nLCBUKQpiaXJkbGlmZV9jaXR5X2RhdGFfbmFtZWQgPC0gZmV0Y2hfY2l0eV9kYXRhX2ZvcignYmlyZGxpZmUnLCBUKQpgYGAKCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpVc2UgY3Jvc3MgdmFsaWRhdGlvbiBhbmQgZHJvcHBpbmcgdGVybXMgdG8gZmluZCBiZXN0IG1vZGVsCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQoKZnVsbCBtb2RlbDogIHJlc3BvbnNlIH4gcmVnaW9uXzEwMGttX3NzbSArIHJlZ2lvbl81MGttX3NzbSArIHJlZ2lvbl81MGttX2VsZXZhdGlvbl9kZWx0YSArIGJpb21lX25hbWUgKyBwb3B1bGF0aW9uX2dyb3d0aAoKCk1lcmxpbiBkYXRhIHNldAotLS0tLS0tLS0tLS0tLS0tCmBgYHtyfQptZXJsaW5fY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCA8LSBtZXJsaW5fY2l0eV9kYXRhX2ZpeGVkW21lcmxpbl9jaXR5X2RhdGFfZml4ZWQkYmlvbWVfbmFtZSAhPSAnQm9yZWFsIEZvcmVzdHMvVGFpZ2EnLF0KYGBgCgpgYGB7cn0KY3YuZ2xtKG1lcmxpbl9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsLCBnbG0oZm9ybXVsYSA9IHJlc3BvbnNlIH4gcmVnaW9uXzEwMGttX3NzbSArIHJlZ2lvbl81MGttX3NzbSArIHJlZ2lvbl81MGttX2VsZXZhdGlvbl9kZWx0YSArIGJpb21lX25hbWUgKyBwb3B1bGF0aW9uX2dyb3d0aCwgZGF0YSA9IG1lcmxpbl9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsKSkkZGVsdGFbMV0KYGBgCgotLSBDVkUgMTkuNzI4NDEKLS0gQ2FuIHdlIGRyb3Agb25lPwoKYGBge3J9CmN2LmdsbShtZXJsaW5fY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCwgZ2xtKGZvcm11bGEgPSByZXNwb25zZSB+IHJlZ2lvbl81MGttX3NzbSArIHJlZ2lvbl81MGttX2VsZXZhdGlvbl9kZWx0YSArIGJpb21lX25hbWUgKyBwb3B1bGF0aW9uX2dyb3d0aCwgZGF0YSA9IG1lcmxpbl9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsKSkkZGVsdGFbMV0KYGBgCgpgYGB7cn0KY3YuZ2xtKG1lcmxpbl9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsLCBnbG0oZm9ybXVsYSA9IHJlc3BvbnNlIH4gcmVnaW9uXzEwMGttX3NzbSArIHJlZ2lvbl81MGttX2VsZXZhdGlvbl9kZWx0YSArIGJpb21lX25hbWUgKyBwb3B1bGF0aW9uX2dyb3d0aCwgZGF0YSA9IG1lcmxpbl9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsKSkkZGVsdGFbMV0KYGBgCgpgYGB7cn0KY3YuZ2xtKG1lcmxpbl9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsLCBnbG0oZm9ybXVsYSA9IHJlc3BvbnNlIH4gcmVnaW9uXzEwMGttX3NzbSArIHJlZ2lvbl81MGttX3NzbSArIGJpb21lX25hbWUgKyBwb3B1bGF0aW9uX2dyb3d0aCwgZGF0YSA9IG1lcmxpbl9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsKSkkZGVsdGFbMV0KYGBgCgpgYGB7cn0KY3YuZ2xtKG1lcmxpbl9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsLCBnbG0oZm9ybXVsYSA9IHJlc3BvbnNlIH4gcmVnaW9uXzEwMGttX3NzbSArIHJlZ2lvbl81MGttX3NzbSArIHJlZ2lvbl81MGttX2VsZXZhdGlvbl9kZWx0YSArIHBvcHVsYXRpb25fZ3Jvd3RoLCBkYXRhID0gbWVybGluX2NpdHlfZGF0YV9maXhlZF9ub19ib3JlYWwpKSRkZWx0YVsxXQpgYGAKCmBgYHtyfQpjdi5nbG0obWVybGluX2NpdHlfZGF0YV9maXhlZF9ub19ib3JlYWwsIGdsbShmb3JtdWxhID0gcmVzcG9uc2UgfiByZWdpb25fMTAwa21fc3NtICsgcmVnaW9uXzUwa21fc3NtICsgcmVnaW9uXzUwa21fZWxldmF0aW9uX2RlbHRhICsgYmlvbWVfbmFtZSwgZGF0YSA9IG1lcmxpbl9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsKSkkZGVsdGFbMV0KYGBgCgotLSBkcm9wIGJpb21lX25hbWUgdG8gZ2l2ZSBzbWFsbGVyIENWRSBvZiAxOC41MzE4MwotLSBjYW4gd2UgZHJvcCBhbm90aGVyPwoKYGBge3J9CmN2LmdsbShtZXJsaW5fY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCwgZ2xtKGZvcm11bGEgPSByZXNwb25zZSB+IHJlZ2lvbl81MGttX3NzbSArIHJlZ2lvbl81MGttX2VsZXZhdGlvbl9kZWx0YSArIHBvcHVsYXRpb25fZ3Jvd3RoLCBkYXRhID0gbWVybGluX2NpdHlfZGF0YV9maXhlZF9ub19ib3JlYWwpKSRkZWx0YVsxXQpgYGAKCmBgYHtyfQpjdi5nbG0obWVybGluX2NpdHlfZGF0YV9maXhlZF9ub19ib3JlYWwsIGdsbShmb3JtdWxhID0gcmVzcG9uc2UgfiByZWdpb25fMTAwa21fc3NtICsgcmVnaW9uXzUwa21fZWxldmF0aW9uX2RlbHRhICsgcG9wdWxhdGlvbl9ncm93dGgsIGRhdGEgPSBtZXJsaW5fY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCkpJGRlbHRhWzFdCmBgYAoKYGBge3J9CmN2LmdsbShtZXJsaW5fY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCwgZ2xtKGZvcm11bGEgPSByZXNwb25zZSB+IHJlZ2lvbl8xMDBrbV9zc20gKyByZWdpb25fNTBrbV9zc20gKyBwb3B1bGF0aW9uX2dyb3d0aCwgZGF0YSA9IG1lcmxpbl9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsKSkkZGVsdGFbMV0KYGBgCgpgYGB7cn0KY3YuZ2xtKG1lcmxpbl9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsLCBnbG0oZm9ybXVsYSA9IHJlc3BvbnNlIH4gcmVnaW9uXzEwMGttX3NzbSArIHJlZ2lvbl81MGttX3NzbSArIHJlZ2lvbl81MGttX2VsZXZhdGlvbl9kZWx0YSwgZGF0YSA9IG1lcmxpbl9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsKSkkZGVsdGFbMV0KYGBgCgotLSBkcm9wIHBvcHVsYXRpb25fZ3Jvd3RoIHRvIGdpdmUgQ1ZFIG9mIDE4LjIwMDk1Ci0tIGNhbiB3ZSBkcm9wIGFub3RoZXI/CgpgYGB7cn0KY3YuZ2xtKG1lcmxpbl9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsLCBnbG0oZm9ybXVsYSA9IHJlc3BvbnNlIH4gcmVnaW9uXzUwa21fc3NtICsgcmVnaW9uXzUwa21fZWxldmF0aW9uX2RlbHRhLCBkYXRhID0gbWVybGluX2NpdHlfZGF0YV9maXhlZF9ub19ib3JlYWwpKSRkZWx0YVsxXQpgYGAKCmBgYHtyfQpjdi5nbG0obWVybGluX2NpdHlfZGF0YV9maXhlZF9ub19ib3JlYWwsIGdsbShmb3JtdWxhID0gcmVzcG9uc2UgfiByZWdpb25fMTAwa21fc3NtICsgcmVnaW9uXzUwa21fZWxldmF0aW9uX2RlbHRhLCBkYXRhID0gbWVybGluX2NpdHlfZGF0YV9maXhlZF9ub19ib3JlYWwpKSRkZWx0YVsxXQpgYGAKCmBgYHtyfQpjdi5nbG0obWVybGluX2NpdHlfZGF0YV9maXhlZF9ub19ib3JlYWwsIGdsbShmb3JtdWxhID0gcmVzcG9uc2UgfiByZWdpb25fMTAwa21fc3NtICsgcmVnaW9uXzUwa21fc3NtLCBkYXRhID0gbWVybGluX2NpdHlfZGF0YV9maXhlZF9ub19ib3JlYWwpKSRkZWx0YVsxXQpgYGAKCi0tIGRyb3AgcmVnaW9uXzUwa21fc3NtIHRvIGdpdmUgQ1ZFIG9mIDE3LjkxMjE2Ci0tIGNhbiB3ZSBkcm9wIGFub3RoZXI/CgpgYGB7cn0KY3YuZ2xtKG1lcmxpbl9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsLCBnbG0oZm9ybXVsYSA9IHJlc3BvbnNlIH4gcmVnaW9uXzEwMGttX3NzbSwgZGF0YSA9IG1lcmxpbl9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsKSkkZGVsdGFbMV0KYGBgCgpgYGB7cn0KY3YuZ2xtKG1lcmxpbl9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsLCBnbG0oZm9ybXVsYSA9IHJlc3BvbnNlIH4gcmVnaW9uXzUwa21fZWxldmF0aW9uX2RlbHRhLCBkYXRhID0gbWVybGluX2NpdHlfZGF0YV9maXhlZF9ub19ib3JlYWwpKSRkZWx0YVsxXQpgYGAKCgotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCi0tIGJlc3QgbW9kZWwgd2l0aCByZWdpb25fMTAwa21fc3NtICsgcmVnaW9uXzUwa21fZWxldmF0aW9uX2RlbHRhIChDViBlcnJvciAxNy45MTIxNikKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQoKYGBge3J9CnN1bW1hcnkoZ2xtKGRhdGEgPSBtZXJsaW5fY2l0eV9kYXRhX2ZpeGVkLCBmb3JtdWxhID0gcmVzcG9uc2UgfiByZWdpb25fMTAwa21fc3NtICsgcmVnaW9uXzUwa21fZWxldmF0aW9uX2RlbHRhKSkKYGBgCgpgYGB7cn0KcmVnX21lcmxpbiA9IGdsbShkYXRhID0gbWVybGluX2NpdHlfZGF0YV9maXhlZCwgZm9ybXVsYSA9IHJlc3BvbnNlIH4gcmVnaW9uXzEwMGttX3NzbSArIHJlZ2lvbl81MGttX2VsZXZhdGlvbl9kZWx0YSkKd2l0aChzdW1tYXJ5KHJlZ19tZXJsaW4pLCAxIC0gZGV2aWFuY2UvbnVsbC5kZXZpYW5jZSkKYGBgCgpCaXJkbGlmZSBkYXRhIHNldAotLS0tLS0tLS0tLS0tLS0tCmBgYHtyfQpiaXJkbGlmZV9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsIDwtIGJpcmRsaWZlX2NpdHlfZGF0YV9maXhlZFtiaXJkbGlmZV9jaXR5X2RhdGFfZml4ZWQkYmlvbWVfbmFtZSAhPSAnQm9yZWFsIEZvcmVzdHMvVGFpZ2EnLF0KYGBgCgpgYGB7cn0KY3YuZ2xtKGJpcmRsaWZlX2NpdHlfZGF0YV9maXhlZF9ub19ib3JlYWwsIGdsbShmb3JtdWxhID0gcmVzcG9uc2UgfiByZWdpb25fMTAwa21fc3NtICsgcmVnaW9uXzUwa21fc3NtICsgcmVnaW9uXzUwa21fZWxldmF0aW9uX2RlbHRhICsgYmlvbWVfbmFtZSArIHBvcHVsYXRpb25fZ3Jvd3RoLCBkYXRhID0gYmlyZGxpZmVfY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCkpJGRlbHRhWzFdCmBgYAoKLS0gY2FuIHdlIGRyb3AgYSB2YXJpYWJsZT8KCmBgYHtyfQpjdi5nbG0oYmlyZGxpZmVfY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCwgZ2xtKGZvcm11bGEgPSByZXNwb25zZSB+IHJlZ2lvbl81MGttX3NzbSArIHJlZ2lvbl81MGttX2VsZXZhdGlvbl9kZWx0YSArIGJpb21lX25hbWUgKyBwb3B1bGF0aW9uX2dyb3d0aCwgZGF0YSA9IGJpcmRsaWZlX2NpdHlfZGF0YV9maXhlZF9ub19ib3JlYWwpKSRkZWx0YVsxXQpgYGAKCmBgYHtyfQpjdi5nbG0oYmlyZGxpZmVfY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCwgZ2xtKGZvcm11bGEgPSByZXNwb25zZSB+IHJlZ2lvbl8xMDBrbV9zc20gKyByZWdpb25fNTBrbV9lbGV2YXRpb25fZGVsdGEgKyBiaW9tZV9uYW1lICsgcG9wdWxhdGlvbl9ncm93dGgsIGRhdGEgPSBiaXJkbGlmZV9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsKSkkZGVsdGFbMV0KYGBgCgpgYGB7cn0KY3YuZ2xtKGJpcmRsaWZlX2NpdHlfZGF0YV9maXhlZF9ub19ib3JlYWwsIGdsbShmb3JtdWxhID0gcmVzcG9uc2UgfiByZWdpb25fMTAwa21fc3NtICsgcmVnaW9uXzUwa21fc3NtICsgYmlvbWVfbmFtZSArIHBvcHVsYXRpb25fZ3Jvd3RoLCBkYXRhID0gYmlyZGxpZmVfY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCkpJGRlbHRhWzFdCmBgYAoKYGBge3J9CmN2LmdsbShiaXJkbGlmZV9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsLCBnbG0oZm9ybXVsYSA9IHJlc3BvbnNlIH4gcmVnaW9uXzEwMGttX3NzbSArIHJlZ2lvbl81MGttX3NzbSArIHJlZ2lvbl81MGttX2VsZXZhdGlvbl9kZWx0YSArIHBvcHVsYXRpb25fZ3Jvd3RoLCBkYXRhID0gYmlyZGxpZmVfY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCkpJGRlbHRhWzFdCmBgYAoKYGBge3J9CmN2LmdsbShiaXJkbGlmZV9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsLCBnbG0oZm9ybXVsYSA9IHJlc3BvbnNlIH4gcmVnaW9uXzEwMGttX3NzbSArIHJlZ2lvbl81MGttX3NzbSArIHJlZ2lvbl81MGttX2VsZXZhdGlvbl9kZWx0YSArIGJpb21lX25hbWUsIGRhdGEgPSBiaXJkbGlmZV9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsKSkkZGVsdGFbMV0KYGBgCgotLSBkcm9wIGJpb21lX25hbWUgdG8gZ2l2ZSBDVkUgb2YgNi41MDM0MjEKLS0gY2FuIHdlIGRyb3AgYW5vdGhlcj8KCmBgYHtyfQpjdi5nbG0oYmlyZGxpZmVfY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCwgZ2xtKGZvcm11bGEgPSByZXNwb25zZSB+IHJlZ2lvbl81MGttX3NzbSArIHJlZ2lvbl81MGttX2VsZXZhdGlvbl9kZWx0YSArIHBvcHVsYXRpb25fZ3Jvd3RoLCBkYXRhID0gYmlyZGxpZmVfY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCkpJGRlbHRhWzFdCmBgYAoKYGBge3J9CmN2LmdsbShiaXJkbGlmZV9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsLCBnbG0oZm9ybXVsYSA9IHJlc3BvbnNlIH4gcmVnaW9uXzEwMGttX3NzbSArIHJlZ2lvbl81MGttX2VsZXZhdGlvbl9kZWx0YSArIHBvcHVsYXRpb25fZ3Jvd3RoLCBkYXRhID0gYmlyZGxpZmVfY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCkpJGRlbHRhWzFdCmBgYAoKCmBgYHtyfQpjdi5nbG0oYmlyZGxpZmVfY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCwgZ2xtKGZvcm11bGEgPSByZXNwb25zZSB+IHJlZ2lvbl8xMDBrbV9zc20gKyByZWdpb25fNTBrbV9zc20gKyBwb3B1bGF0aW9uX2dyb3d0aCwgZGF0YSA9IGJpcmRsaWZlX2NpdHlfZGF0YV9maXhlZF9ub19ib3JlYWwpKSRkZWx0YVsxXQpgYGAKCgpgYGB7cn0KY3YuZ2xtKGJpcmRsaWZlX2NpdHlfZGF0YV9maXhlZF9ub19ib3JlYWwsIGdsbShmb3JtdWxhID0gcmVzcG9uc2UgfiByZWdpb25fMTAwa21fc3NtICsgcmVnaW9uXzUwa21fc3NtICsgcmVnaW9uXzUwa21fZWxldmF0aW9uX2RlbHRhLCBkYXRhID0gYmlyZGxpZmVfY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCkpJGRlbHRhWzFdCmBgYAoKLS0gZHJvcCByZWdpb25fMTAwa21fc3NtIHRvIGdpdmUgQ1ZFIG9mIDYuNDE3MzExCi0tIGNhbiB3ZSBkcm9wIGFub3RoZXI/CgpgYGB7cn0KY3YuZ2xtKGJpcmRsaWZlX2NpdHlfZGF0YV9maXhlZF9ub19ib3JlYWwsIGdsbShmb3JtdWxhID0gcmVzcG9uc2UgfiByZWdpb25fNTBrbV9lbGV2YXRpb25fZGVsdGEgKyBwb3B1bGF0aW9uX2dyb3d0aCwgZGF0YSA9IGJpcmRsaWZlX2NpdHlfZGF0YV9maXhlZF9ub19ib3JlYWwpKSRkZWx0YVsxXQpgYGAKCmBgYHtyfQpjdi5nbG0oYmlyZGxpZmVfY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCwgZ2xtKGZvcm11bGEgPSByZXNwb25zZSB+IHJlZ2lvbl81MGttX3NzbSArIHBvcHVsYXRpb25fZ3Jvd3RoLCBkYXRhID0gYmlyZGxpZmVfY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCkpJGRlbHRhWzFdCmBgYAoKYGBge3J9CmN2LmdsbShiaXJkbGlmZV9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsLCBnbG0oZm9ybXVsYSA9IHJlc3BvbnNlIH4gcmVnaW9uXzUwa21fc3NtICsgcmVnaW9uXzUwa21fZWxldmF0aW9uX2RlbHRhLCBkYXRhID0gYmlyZGxpZmVfY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCkpJGRlbHRhWzFdCmBgYAoKLS0gZHJvcCByZWdpb25fNTBrbV9lbGV2YXRpb25fZGVsdGEgdG8gZ2l2ZSBDVkUgb2YgNi4zNDIwMjUKLS0gY2FuIHdlIGRyb3AgYW5vdGhlcj8KCmBgYHtyfQpjdi5nbG0oYmlyZGxpZmVfY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCwgZ2xtKGZvcm11bGEgPSByZXNwb25zZSB+IHBvcHVsYXRpb25fZ3Jvd3RoLCBkYXRhID0gYmlyZGxpZmVfY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCkpJGRlbHRhWzFdCmBgYAoKYGBge3J9CmN2LmdsbShiaXJkbGlmZV9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsLCBnbG0oZm9ybXVsYSA9IHJlc3BvbnNlIH4gcmVnaW9uXzUwa21fc3NtLCBkYXRhID0gYmlyZGxpZmVfY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbCkpJGRlbHRhWzFdCmBgYAoKLS0gZHJvcCBjaXR5X2dkcF9wZXJfcG9wdWxhdGlvbiB0byBnaXZlIENWRSBvZiA2LjI5MTI5OQotLSBpcyB0aGlzIGJldHRlciB0aGFuIG5vIHZhcmlhYmxlPwoKYGBge3J9CmN2LmdsbShiaXJkbGlmZV9jaXR5X2RhdGFfZml4ZWRfbm9fYm9yZWFsLCBnbG0oZm9ybXVsYSA9IHJlc3BvbnNlIH4gMSwgZGF0YSA9IGJpcmRsaWZlX2NpdHlfZGF0YV9maXhlZF9ub19ib3JlYWwpKSRkZWx0YVsxXQpgYGAKLS0geWVzLCBqdXN0IQoKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQotLSBzbyBiZXN0IG1vZGVsIHdpdGggYmlyZGxpZmUgaXMgcmVnaW9uXzUwa21fc3NtCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCmBgYHtyfQpzdW1tYXJ5KGdsbShkYXRhID0gYmlyZGxpZmVfY2l0eV9kYXRhX2ZpeGVkLCBmb3JtdWxhID0gcmVzcG9uc2UgfiByZWdpb25fNTBrbV9zc20pKQpgYGAKCmBgYHtyfQpyZWdfYmlyZGxpZmUgPSBnbG0oZGF0YSA9IGJpcmRsaWZlX2NpdHlfZGF0YV9maXhlZCwgZm9ybXVsYSA9IHJlc3BvbnNlIH4gcmVnaW9uXzUwa21fc3NtKQp3aXRoKHN1bW1hcnkocmVnX2JpcmRsaWZlKSwgMSAtIGRldmlhbmNlL251bGwuZGV2aWFuY2UpCmBgYAoKCmBgYHtyfQpnZ3Bsb3QoYmlyZGxpZmVfY2l0eV9kYXRhX25hbWVkLCBhZXMoeCA9IHJlZ2lvbl81MGttX3NzbSwgeSA9IHJlc3BvbnNlKSkgKyBnZW9tX3BvaW50KCkgKyBnZW9tX3Ntb290aChtZXRob2QgPSAiZ2xtIikKYGBgCgoKCgotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KQ2hlY2sgYmlyZGxpZmUgbW9kZWwgZml0Ci0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQoKYGBge3J9CmJpcmRsaWZlLmZpdCA8LSBnbG0oZGF0YSA9IGJpcmRsaWZlX2NpdHlfZGF0YV9maXhlZCwgZm9ybXVsYSA9IHJlc3BvbnNlIH4gcmVnaW9uXzUwa21fc3NtKQpzdW1tYXJ5KGJpcmRsaWZlLmZpdCkKd2l0aChzdW1tYXJ5KGJpcmRsaWZlLmZpdCksIDEgLSBkZXZpYW5jZS9udWxsLmRldmlhbmNlKQpwbG90KGJpcmRsaWZlLmZpdCkKYGBgCgpgYGB7cn0KYmlyZGxpZmVfY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbFtjKDE2LCA1MywgNzIpLCBjKCJyZWdpb25fNTBrbV9zc20iKV0KYGBgCgpgYGB7cn0KY2l0eV9kYXRhW2MoMTYsIDUzLCA3MiksIGMoIm5hbWUiLCAicmVnaW9uXzUwa21fc3NtIildCmBgYAoKYGBge3J9CmRhdCA8LSBwcmVkaWN0KGdsbShmb3JtdWxhID0gcmVzcG9uc2UgfiByZWdpb25fNTBrbV9zc20sIGRhdGEgPSBiaXJkbGlmZV9jaXR5X2RhdGFfbmFtZWQpLCBzZS5maXQ9VCkKCm91dHNpZGVfc2UgPC0gYmlyZGxpZmVfY2l0eV9kYXRhX25hbWVkW2JpcmRsaWZlX2NpdHlfZGF0YV9uYW1lZCRyZXNwb25zZSA8IGRhdCRmaXQgLSAxNSogZGF0JHNlLmZpdCB8IGJpcmRsaWZlX2NpdHlfZGF0YV9uYW1lZCRyZXNwb25zZSA+IGRhdCRmaXQgKyAxNSAqIGRhdCRzZS5maXQsXQoKZ2dwbG90KGJpcmRsaWZlX2NpdHlfZGF0YV9uYW1lZCwgYWVzKHggPSByZWdpb25fNTBrbV9zc20sIHkgPSByZXNwb25zZSkpICsgCiAgZ2VvbV9wb2ludChzaXplPTEpICsgCiAgZ2VvbV9zbW9vdGgobWV0aG9kID0gImdsbSIpICsKICBnZW9tX3RleHQoYWVzKGxhYmVsID0gbmFtZSksIGRhdGEgPSBvdXRzaWRlX3NlLCBzaXplID0gMywgcG9zaXRpb24gPSAiZG9kZ2UiLCB2anVzdCA9ICJpbndhcmQiLCBoanVzdCA9ICJpbndhcmQiLCBjb2xvciA9ICJyZWQiLCBhbmdsZT0tMTUpICsKICBnZW9tX3BvaW50KGRhdGEgPSBvdXRzaWRlX3NlLCBjb2xvciA9ICJyZWQiKSArCiAgdGhlbWVfYncoKSArCiAgeWxhYigiQ2l0eSBSYW5kb20gRWZmZWN0IEludGVyY2VwdCIpICsgeGxhYigiUmVnaW9uYWwgKDUwa20pIFNTTSIpICsgbGFicyh0aXRsZSA9ICJCaXJkbGlmZSIpCgpnZ3NhdmUoImNpdHlfZWZmZWN0X3JpY2huZXNzX19vdXRwdXRfX2JpcmRsaWZlLmpwZyIpCmBgYAoKSG93IG11Y2ggdmFyaWF0aW9uIGhhdmUgd2UgZXhwbGFpbmVkPwotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCmBgYHtyfQpiaXJkbGlmZV9jaXR5X2RhdGFfbmFtZWQkcmVzaWR1YWxzIDwtIHJlc2lkKGJpcmRsaWZlLmZpdCkKZ2dwbG90KGJpcmRsaWZlX2NpdHlfZGF0YV9uYW1lZCwgYWVzKHkgPSByZXNwb25zZSwgeCA9IHJlc2lkdWFscykpICsgCiAgZ2VvbV9wb2ludCgpICsKICBnZW9tX3Ntb290aChtZXRob2QgPSAibG0iLCBzZSA9IEYpICsKICBsYWJzKHRpdGxlID0gIkJpcmRsaWZlIiwgc3VidGl0bGUgPSBwYXN0ZSgiQ29ycmVsYXRpb24iLCBjb3IoYmlyZGxpZmVfY2l0eV9kYXRhX25hbWVkJHJlc2lkdWFscywgYmlyZGxpZmVfY2l0eV9kYXRhX25hbWVkJHJlc3BvbnNlKSkpICsKICB0aGVtZV9idygpCmBgYAoKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCkNoZWNrIE1lcmxpbiBtb2RlbCBmaXQKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgpgYGB7cn0KbWVybGluLmZpdCA8LSBnbG0oZGF0YSA9IG1lcmxpbl9jaXR5X2RhdGFfbmFtZWQsIGZvcm11bGEgPSByZXNwb25zZSB+IHJlZ2lvbl8xMDBrbV9zc20gKyByZWdpb25fNTBrbV9lbGV2YXRpb25fZGVsdGEpCnN1bW1hcnkobWVybGluLmZpdCkKd2l0aChzdW1tYXJ5KG1lcmxpbi5maXQpLCAxIC0gZGV2aWFuY2UvbnVsbC5kZXZpYW5jZSkKcGxvdChtZXJsaW4uZml0KQpgYGAKCmBgYHtyfQptZXJsaW5fY2l0eV9kYXRhX2ZpeGVkX25vX2JvcmVhbFtjKDI0LCA0MiwgNzIpLCBjKCJyZWdpb25fMTAwa21fc3NtIiwgInJlZ2lvbl81MGttX2VsZXZhdGlvbl9kZWx0YSIpXQpgYGAKCmBgYHtyfQpjaXR5X2RhdGFbYygyNCwgNDIsIDcyKSwgYygibmFtZSIsICJyZWdpb25fMTAwa21fc3NtIiwgInJlZ2lvbl81MGttX2VsZXZhdGlvbl9kZWx0YSIpXQpgYGAKCmBgYHtyfQpnZ3Bsb3QobWVybGluX2NpdHlfZGF0YV9uYW1lZCwgYWVzKHggPSByZWdpb25fMTAwa21fc3NtLCB5ID0gcmVzcG9uc2UpKSArIAogIGdlb21fcG9pbnQoYWVzKHNpemUgPSByZWdpb25fNTBrbV9lbGV2YXRpb25fZGVsdGEpKSArIAogIGdlb21fc21vb3RoKG1ldGhvZCA9ICJnbG0iKSArCiAgdGhlbWVfYncoKSArCiAgdGhlbWUobGVnZW5kLnBvc2l0aW9uPSJib3R0b20iKSArCiAgeWxhYigiQ2l0eSBSYW5kb20gRWZmZWN0IEludGVyY2VwdCIpICsgeGxhYigiUmVnaW9uYWwgKDEwMGttKSBTU00iKSArIGxhYnModGl0bGUgPSAiZUJpcmQiKSArIGd1aWRlcyhzaXplPWd1aWRlX2xlZ2VuZCh0aXRsZT0iUmVnaW9uYWwgKDUwa20pIEVsZXZhdGlvbiBEZWx0YSIpKQoKZ2dzYXZlKCJjaXR5X2VmZmVjdF9yaWNobmVzc19fb3V0cHV0X19tZXJsaW4uanBnIikKYGBgCgpIb3cgbXVjaCB2YXJpYXRpb24gaGF2ZSB3ZSBleHBsYWluZWQ/Ci0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpgYGB7cn0KbWVybGluX2NpdHlfZGF0YV9uYW1lZCRyZXNpZHVhbHMgPC0gcmVzaWQobWVybGluLmZpdCkKZ2dwbG90KG1lcmxpbl9jaXR5X2RhdGFfbmFtZWQsIGFlcyh5ID0gcmVzcG9uc2UsIHggPSByZXNpZHVhbHMpKSArIAogIGdlb21fcG9pbnQoKSArCiAgZ2VvbV9zbW9vdGgobWV0aG9kID0gImxtIiwgc2UgPSBGKSArCiAgbGFicyh0aXRsZSA9ICJNZXJsaW4iLCBzdWJ0aXRsZSA9IHBhc3RlKCJDb3JyZWxhdGlvbiIsIGNvcihtZXJsaW5fY2l0eV9kYXRhX25hbWVkJHJlc2lkdWFscywgbWVybGluX2NpdHlfZGF0YV9uYW1lZCRyZXNwb25zZSkpKSArCiAgdGhlbWVfYncoKQpgYGAKCgotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCkNoZWNrIEFJQwotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCgpgYGB7cn0KQUlDKAogIGdsbShkYXRhID0gbWVybGluX2NpdHlfZGF0YV9maXhlZCwgZm9ybXVsYSA9IHJlc3BvbnNlIH4gcmVnaW9uXzEwMGttX3NzbSArIHJlZ2lvbl81MGttX3NzbSArIHJlZ2lvbl81MGttX2VsZXZhdGlvbl9kZWx0YSArIGJpb21lX25hbWUgKyBwb3B1bGF0aW9uX2dyb3d0aCksCiAgZ2xtKGRhdGEgPSBtZXJsaW5fY2l0eV9kYXRhX2ZpeGVkLCBmb3JtdWxhID0gcmVzcG9uc2UgfiByZWdpb25fMTAwa21fc3NtICsgcmVnaW9uXzUwa21fZWxldmF0aW9uX2RlbHRhKQopCmBgYAoKYGBge3J9CkFJQygKICBnbG0oZGF0YSA9IGJpcmRsaWZlX2NpdHlfZGF0YV9maXhlZCwgZm9ybXVsYSA9IHJlc3BvbnNlIH4gcmVnaW9uXzEwMGttX3NzbSArIHJlZ2lvbl81MGttX3NzbSArIHJlZ2lvbl81MGttX2VsZXZhdGlvbl9kZWx0YSArIGJpb21lX25hbWUgKyBwb3B1bGF0aW9uX2dyb3d0aCksCiAgZ2xtKGRhdGEgPSBiaXJkbGlmZV9jaXR5X2RhdGFfZml4ZWQsIGZvcm11bGEgPSByZXNwb25zZSB+IHJlZ2lvbl81MGttX3NzbSkKKQpgYGAKCgoKLS0tLS0tLS0tLS0tLS0tLS0tLS0tCkxERwotLS0tLS0tLS0tLS0tLS0tLS0tLS0tCmBgYHtyfQpiaXJkbGlmZV9kYXRhX3dpdGhfbGF0ID0gZmV0Y2hfY2l0eV9kYXRhX2ZvcignYmlyZGxpZmUnLCBpbmNsdWRlX2NpdHlfbmFtZSA9IFQpCgpkYXQyIDwtIHByZWRpY3QoZ2xtKGZvcm11bGEgPSByZXNwb25zZSB+IGNpdHlfY2VudHJlX2xhdGl0dWRlLCBkYXRhID0gYmlyZGxpZmVfZGF0YV93aXRoX2xhdCksIHNlLmZpdD1UKQoKb3V0c2lkZV9zZSA8LSBiaXJkbGlmZV9kYXRhX3dpdGhfbGF0W2JpcmRsaWZlX2RhdGFfd2l0aF9sYXQkcmVzcG9uc2UgPCBkYXQyJGZpdCAtIDE1KiBkYXQyJHNlLmZpdCB8IGJpcmRsaWZlX2RhdGFfd2l0aF9sYXQkcmVzcG9uc2UgPiBkYXQyJGZpdCArIDE1ICogZGF0MiRzZS5maXQsXQoKZ2dwbG90KGJpcmRsaWZlX2RhdGFfd2l0aF9sYXQsIGFlcyh4ID0gY2l0eV9jZW50cmVfbGF0aXR1ZGUsIHkgPSByZXNwb25zZSkpICsgCiAgZ2VvbV9wb2ludChzaXplPTEpICsgCiAgZ2VvbV9zbW9vdGgobWV0aG9kID0gImdsbSIsIGZvcm11bGEgPSB5IH4gSSh4XjIpKSArCiAgZ2VvbV90ZXh0KGFlcyhsYWJlbCA9IG5hbWUpLCBkYXRhID0gb3V0c2lkZV9zZSwgc2l6ZSA9IDMsIHBvc2l0aW9uID0gImRvZGdlIiwgdmp1c3QgPSAiaW53YXJkIiwgaGp1c3QgPSAiaW53YXJkIiwgY29sb3IgPSAicmVkIiwgYW5nbGU9LTE1KSArCiAgZ2VvbV9wb2ludChkYXRhID0gb3V0c2lkZV9zZSwgY29sb3IgPSAicmVkIikgKwogIHRoZW1lX2J3KCkgKwogIHlsYWIoIkNpdHkgUmFuZG9tIEVmZmVjdCBJbnRlcmNlcHQiKSArIHhsYWIoIkxhdGl0dWRlIChvZiBjaXR5IGNlbnRyZSkiKSArIGxhYnModGl0bGUgPSAiQmlyZGxpZmUiKQoKZ2dzYXZlKCdjaXR5X2VmZmVjdF9yaWNobmVzc19fb3V0cHV0X19sZGdfYmlyZGxpZmUuanBnJykKYGBgCgoKYGBge3J9Cm1lcmxpbl9kYXRhX3dpdGhfbGF0ID0gZmV0Y2hfY2l0eV9kYXRhX2ZvcignbWVybGluJywgaW5jbHVkZV9jaXR5X25hbWUgPSBUKQoKZGF0MiA8LSBwcmVkaWN0KGdsbShmb3JtdWxhID0gcmVzcG9uc2UgfiBjaXR5X2NlbnRyZV9sYXRpdHVkZSwgZGF0YSA9IG1lcmxpbl9kYXRhX3dpdGhfbGF0KSwgc2UuZml0PVQpCgpvdXRzaWRlX3NlIDwtIG1lcmxpbl9kYXRhX3dpdGhfbGF0W21lcmxpbl9kYXRhX3dpdGhfbGF0JHJlc3BvbnNlIDwgZGF0MiRmaXQgLSAxNSogZGF0MiRzZS5maXQgfCBtZXJsaW5fZGF0YV93aXRoX2xhdCRyZXNwb25zZSA+IGRhdDIkZml0ICsgMTUgKiBkYXQyJHNlLmZpdCxdCgpnZ3Bsb3QobWVybGluX2RhdGFfd2l0aF9sYXQsIGFlcyh4ID0gY2l0eV9jZW50cmVfbGF0aXR1ZGUsIHkgPSByZXNwb25zZSkpICsgCiAgZ2VvbV9wb2ludChzaXplPTEpICsgCiAgZ2VvbV9zbW9vdGgobWV0aG9kID0gImdsbSIsIGZvcm11bGEgPSB5IH4gSSh4XjIpKSArCiAgZ2VvbV90ZXh0KGFlcyhsYWJlbCA9IG5hbWUpLCBkYXRhID0gb3V0c2lkZV9zZSwgc2l6ZSA9IDMsIHBvc2l0aW9uID0gImRvZGdlIiwgdmp1c3QgPSAiaW53YXJkIiwgaGp1c3QgPSAiaW53YXJkIiwgY29sb3IgPSAicmVkIiwgYW5nbGU9LTE1KSArCiAgZ2VvbV9wb2ludChkYXRhID0gb3V0c2lkZV9zZSwgY29sb3IgPSAicmVkIikgKwogIHRoZW1lX2J3KCkgKwogIHlsYWIoIkNpdHkgUmFuZG9tIEVmZmVjdCBJbnRlcmNlcHQiKSArIHhsYWIoIkxhdGl0dWRlIChvZiBjaXR5IGNlbnRyZSkiKSArIGxhYnModGl0bGUgPSAiZUJpcmQiKQoKZ2dzYXZlKCdjaXR5X2VmZmVjdF9yaWNobmVzc19fb3V0cHV0X19sZGdfbWVybGluLmpwZycpCmBgYA==